草庐IT

MySQL、Rails ActiveRecord 日期分组和时区

全部标签

ruby-on-rails - 如何在 Ruby 中将 MS Excel 日期从 float 转换为日期格式?

尝试在ruby​​脚本中使用roogem解析XLSX文件。在Excel中,日期以DDDDD.ttttt格式存储为float或整数,从1900-01-00(00no01)开始计算。因此,为了转换诸如40396之类的日期-您将使用1900-01-00+40396,您应该得到2010-10-15,但我得到的是2010-08-08。我正在使用active_support/time进行这样的计算:Time.new("1900-01-01")+40396.days我的计算有误还是主动支持有问题?我在Windows7+最新的active_supportgem(3.2.1)上运行ruby​​1.9.3

ruby - 按特定值对 Ruby 数组进行分组

我有一个数组,我只想选择两个指定值之间的元素。例如,我有一个如下所示的数组:a=["don'twant","don'twant","Start","want","want","Stop","don'twant","Start","want","Stop","don'twant"]我想在数组上调用一个方法来捕获“Start”和“Stop”之间的元素(包括“Start”和“Stop”元素)。生成的数组应如下所示:[["Start","want","want","Stop"],["Start","want","Stop"]]我找不到这样的方法,所以我试着写了一个:classArraydefg

ruby 正则表达式和分组

我有以下文字'some-text-here'并尝试获取'text'使用组从中提取单词。如果我使用那个表达式/some-(\w+)-here/一切正常,但如果我尝试对其应用分组/some-(?\w+)-here/它引发了一个错误Undefined(?...)sequence.我做错了什么?(ruby1.9.2)更新:我真丢人。这一切都是出于我的本能。是的,我已经使用RVM并且我的ruby​​版本开启了1.9.2。但我已经在http://rubular.com/测试了该表达式它写在页脚RubularrunsonRuby1.8.7.Ruby1.8.7和Ruby1.9.2有不同的正则表达式引擎

ruby - 我如何使用 Ruby 来解析时间,就像它在我指定的时区中一样,时区格式为 America/Los_Angeles?

我希望能够从Ruby(1.8.7)中的字符串解析时间,其中该字符串不包含任何时区信息。我想将字符串视为处于以这种格式指定的多个时区中的任何一个:'America/New_York'。时间字符串示例:'2010-02-0501:00:01'我花了很长时间试图解决这个问题。我确实找到了一个类似的问题,但它的答案不适用于我的情况:HowdoIgetRubytoparsetimeasifitwereinadifferenttimezone?上述解决方案的问题是我的时区不能全部以Time.parse(http://www.ruby-doc.org/stdlib-1.8.7/libdoc/time

DolphinScheduler 调度 DataX 实现 MySQL To ElasticSearch 增量数据同步实践

数据同步的方式数据同步的2大方式基于SQL查询的CDC(ChangeDataCapture):离线调度查询作业,批处理。把一张表同步到其他系统,每次通过查询去获取表中最新的数据。也就是我们说的基于SQL查询抽取;无法保障数据一致性,查的过程中有可能数据已经发生了多次变更;不保障实时性,基于离线调度存在天然的延迟;工具软件以Kettle(ApacheHop最新版)、DataX为代表,需要结合任务调度系统使用。基于日志的CDC:实时消费日志,流处理,例如MySQL的binlog日志完整记录了数据库中的变更,可以把binlog文件当作流的数据源;保障数据一致性,因为binlog文件包含了所有历史变更

ruby-on-rails - 为什么我不能解析保存到 Ruby 变量中的日期字符串?

我需要在我的Rails应用程序中运行以下代码:ActiveSupport::TimeZone["CentralTime(US&Canada)"].parse(game.date).utc.to_date.strftime("%_m/%d")[1..-1]游戏在哪里@games.eachdo|game|但这不起作用,我收到错误,TypeError:没有将ActiveSupport::TimeWithZone隐式转换为String。但是,我可以运行:ActiveSupport::TimeZone["CentralTime(US&Canada)"].parse("2014-04-1112am

ruby-on-rails - 更新到 Ubuntu 16.04 后 mysql2 gem 不工作 - libmysqlclient.so.18

更新前一切正常。将ruby​​1.9.3p392与RVM和rails(3.2.12)结合使用使用MySQL5.7.16和Nginx和Unicorn日志显示LoadError:libmysqlclient.so.18:cannotopensharedobjectfile:Nosuchfileordirectory-/home/bill/apps/xxx/shared/bundle/ruby/1.9.1/gems/mysql2-0.3.16/lib/mysql2/mysql2.so我试过:卸载/安装mysql2gem运行捆绑安装没有任何效果。更新后有人遇到这个问题吗?

Ruby - 更改时间实例的日期部分

我有一个值为Time.now的时间实例curr_time和另一个值为“2010年4月17日”的字符串target_date。如何将变量curr_time中的日期部分更改为target_date的值?>>curr_time=>SunFeb2123:37:27+05302010>>target_date=>"Apr17,2010"我希望curr_time像这样改变:>>curr_time=>SatApr1723:37:27+05302010如何实现? 最佳答案 如果您使用activesupport(例如在rails环境中,或者通过req

ruby-on-rails - 是否可以在 Rails 中的两个日期之间创建月份列表

我正在尝试创建一个页面来显示每个月的链接列表,按年分组。月份需要介于今天和第一个条目的日期这两个日期之间。我在一堵砖墙前,我不知道如何创建它。我们将不胜感激任何帮助问候亚当 最佳答案 只需将您想要的内容放入范围循环中,然后像这样使用Date::MONTHNAMES数组(date.year..laterdate.year).eachdo|y|mo_start=(date.year==y)?date.month:1mo_end=(laterdate.year==y)?laterdate.month:12(mo_start..mo_end

ruby-on-rails - 验证时区在 Rails 中是否有效

我正在使用tsjzt:http://pellepim.bitbucket.org/jstz/在客户端获取我存储在用户对象中的当前用户时区。这很好用,并为我提供了像“欧洲/伦敦”这样的时区。我想在将其传递到模型时验证它是一个有效的时区,以防发生不好的事情。所以我发现了这个问题:IssuevalidatingusertimezoneforRailsapponHeroku并尝试了这个验证:validates_inclusion_of:timezone,:in=>{in:ActiveSupport::TimeZone.zones_map(&:name)}但是名称与tzinfo不同。我认为我的客